<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <!-- import CSS -->
  <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<div id="app">
  <h1><a href="/list.html">微博列表页面</a></h1>
  <!--action:文件上传地址
  name:参数名
  on-success图片上传完成时调用的方法-->
  <el-upload
          action="/upload"
          name="picFile"
          :on-success="uploadSuccess"
          list-type="picture-card"
          :on-preview="handlePictureCardPreview"
          :on-remove="handleRemove">
    <i class="el-icon-plus"></i>
  </el-upload>
  <el-dialog :visible.sync="dialogVisible">
    <img width="100%" :src="dialogImageUrl" alt="">
  </el-dialog>
  <form action="">
    <input type="text" name="content" v-model="weibo.content" placeholder="说点儿什么...">
    <input type="button" value="发布微博" @click="send()">
  </form>

</div>
</body>
<script src="js/vue.min.js"></script>
<!-- import JavaScript -->
<script src="js/eui.js"></script>

<script src="js/axios.min.js"></script>
<script>
  let v = new Vue({
    el: '#app',
    data: function() {
      return {
        dialogImageUrl: '',
        dialogVisible: false,
        weibo:{
          content:"",
          urls:"",//urls表示上传多张图片的路径
        }
      }
    },
    methods: {
      handleRemove(file, fileList) {
        //file.response得到图片在服务器的路径
        console.log("删除的图片路径:"+file.response);
        axios.get("/remove?name="+file.response).then(function (response){
          alert("服务器图片已删除!")
        })
        //fileList代表此时客户端上传过的所有文件对象
        //把所有文件对象中的图片路径得到拼接成一个字符串
        let arr = [];
        for (let f of fileList) {
          arr.push(f.response)//f.response代表服务器上传完图片返回的图片路径
        }
        //把数据里面的图片路径通过toString可以拼接成一个字符串
        v.weibo.urls = arr.toString();
      },
      handlePictureCardPreview(file) {
        this.dialogImageUrl = file.url;
        this.dialogVisible = true;
      },
      uploadSuccess(response,file,fileList){//文件上传完成后会调用此方法
        console.log("上传完成:"+response);
        //fileList代表此时客户端上传过的所有文件对象
        //把所有文件对象中的图片路径得到拼接成一个字符串
        let arr = [];
        for (let f of fileList) {
          arr.push(f.response)//f.response代表服务器上传完图片返回的图片路径
        }
        //把数据里面的图片路径通过toString可以拼接成一个字符串
        v.weibo.urls = arr.toString();
      },
      send(){
        //如果提交的参数为JS中的自定义对象,在Controller中接受参数时需要添加一个注解
        axios.post("/insert",v.weibo).then(function (){
          alert("微博发布完成!")
          location.reload();
        })
      }
    }
  })
</script>
</html>